home *** CD-ROM | disk | FTP | other *** search
/ Amiga Format CD 49 / Amiga Format CD49 (2000-01-17)(Future Publishing)(GB)(Track 1 of 3)[!][issue 2000-02].iso / -serious- / programming / c / pmm / make / projekt < prev    next >
Text File  |  1999-11-30  |  7KB  |  151 lines

  1. ; Diese Datei stellt ein Projekt dar. Hier wird auf die
  2. ; Programm-Dateien verwiesen, alle Pfade werden hier
  3. ; gesetzt. * gilt immer, außer ein Programm übersteuert.
  4. ; $1, $2 ... $9 (Variablen für pmm.cfg)
  5. ; $$.c=  Pfad für Source, wenn nicht identisch mit PFAD=
  6. ;
  7. ; Wichtig:
  8. ; Hier angegebene Include-Pfade sind nur für den Compiler
  9. ; und nicht für den Depend-Scan. Der Scan hat seine Include-
  10. ; pfade in der Pmm.UsrIncludes. Aufbau: Pro Zeile ein Include.
  11. ; Der Compiler sucht natürlich auch in in den Standard-Compiler-
  12. ; includes während der Depend-Scan ALLE Pfade mit den eigenen Dateien
  13. ; enthält. Bei Bedarf kommt vielleicht include/libraries mit da rein.
  14. ; Aber jedes Compiler-.h-File zu prüfen ist Unsinn. Nach einem Compiler-
  15. ; update sollte man ohnehin alles einheitlich neu übersetzen.
  16. ; Es ist für den Dependscan nicht nötig programmabhängig zu verwalten.
  17. ; Die Config dient mehr dem Ausschluß von Pfaden, nur wäre das wesent-
  18. ; lich mehr Arbeit. Der Homepfad der Sourcen ist für Depend immer ent-
  19. ; halten. Beim Compilieren wird der Pfad gebraucht, weil er an den
  20. ; Preprozessor übergeben werden muß. Pmm könnte das zwar auch alleine
  21. ; einsetzen, aber das würde die Möglichkeiten beschränken. Also immer
  22. ; -I$I als Include übergeben.
  23. ;
  24. ; Die Zeilen mit MAKE am Anfang:
  25. ; Hier bekommen die Zahlencodes 1%, 2% usw. ihre Zuordnung.
  26. ; MAKE=5 bedeutet: Make ohne Zusatz stellt Definition 5 her (ist als
  27. ;                  68040 vordefiniert).
  28. ; MAKE:xyz=1,2,3   Besagt nichts weiter als das Pmm ... -o xyz die
  29. ;                  Definitionen 1, 2 und 3 erstellen soll, so wie
  30. ;                  bei Make xyz im Makefile 'xyz:' als Festlegung für
  31. ;                  Aufrufparameter steht.
  32. ; MAKE:ALL=....    Das ist die Festlegung, welche Definitionen bei
  33. ;                  Pmm A, Q, I oder Pmm -o ALL erzeugt werden.
  34. ; Diese Einstellungen sind eine Erweiterung zu Pmm.Cfg, aber es geht
  35. ; weiter...
  36. ;
  37. ; Source und sonstige Files:
  38. ; $&.c ist source.c     Preprozessor Input  ( .c -> vcpp )
  39. ; $&.i ist soirce.i     Preprozessor Output ( .c -> vcpp -> .i )
  40. ; $&.a ist source.asm   Compiler Output     ( .i -> vbcc -> .asm )
  41. ; $&.s ist source.s     Compiler Output     ( .i -> vbcc -> .s (vsc) -> .asm )
  42. ; $&.o ist source.o     Assembler Output    ( .asm -> Assembler -> .o [ -> Linker] )
  43. ; $$   ist PROGRAMM     Letzter Output (Programm, Library, Lib etc.)
  44. ; vsc ist der Scheduler, siehe Docs für Warp-Version!!!
  45. ; Dies alles geschieht automatisch. Für .i, .a, .s und .o werden nur noch die
  46. ; Pfade festgelegt. Bei $$ der Name des Programmes INCL. Pfad, wenn gewünscht.
  47. ; Falls nicht, wird a.out imaktuellen Verzeichnis benutzt. Siehe $$ unten...
  48. ; $L Ergänzung der .Lib/.a-Dateien für den Linker.
  49. ;
  50. ; Warum dieser Eintrag, ginge doch genauso gut in Pmm.Cfg?
  51. ; WEIL Pmm.Cfg nur Dinge enthalten sollte die allgemein gültig sind.
  52. ; Diese Projektdatei wird künftig mehrfach angelegt werden können, so
  53. ; das Projekte in Sub-Projekte unterteilt werden können, bzw. auch
  54. ; mehrere Projekte möglich werden. Dann sollte hier das stehen, was
  55. ; für das Projekt vom sonstigen Standard abweicht.
  56. ;
  57. :BEGIN *
  58. MAKE=5
  59. MAKE:60=5,6
  60. MAKE:PPC=7,8
  61. MAKE:ALL=1,2,3,4,5,6,7,8
  62. $&.o=obj/$0/
  63. $&.i=T:
  64. $&.a=T:
  65. $&.s=T:
  66. $L=-Bsymbolic Lib:DOSLIB_$0$8 Lib:All$9
  67. 7%$L=-Bdynamic Lib:DOSLIB_$0$8 Lib:All$9
  68. :END
  69. ;    <- Das END in der vorigen Zeile beendet die Config. AB hier kann
  70. ;       wieder ein BEGIN gesetzt werden. $o ist der Name für ein Temp-File
  71. ;       das die Lise der Objektfiles für den Linker enthält. Diese wird
  72. ;       von Pmm erstellt.
  73. ; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
  74. ;
  75. ; DEMO-EINTRAG -- KEINE FUNKTION --
  76. ; ----------------------------------
  77. ; DOSLIB ist ein SPECIAL, der Linker wird übersteuert mit L=PmmLibr!
  78. ;        Hier entsteht eine .LIB, gesteuert über den eigenen Libr-Befehl
  79. ;        Um Libr wie einen Linker funktionieren zu lassen ist die
  80. ;        Steuerung F aufgenommen worden. Diese Version eines Libr könnte
  81. ;        auch ohne Probleme z.B. in vc integriert werden. Da hätte nur
  82. ;        mal jemand früher drauf kommen müssen (meine erste Version war
  83. ;        ein List-Batch wie bei 7% noch zu sehen).
  84. ;        Y0 startet einen Stub-Batch der weitere Link-Libs erstellt, wenn
  85. ;        dies notwendig ist (siehe Verzeichnis Batch).
  86. ;        Bei PPC wird Y1 als Erweiterung von L= eingesetzt, so kommt der
  87. ;        Batch zur Ausführung und das .a-File für PPC wird gebildet.
  88.  
  89. ; ACHTUNG! Zur Verdeutlichung einer weiteren Funktion folgt in diesem Teil
  90. ;          ein NOMAKE=2,3,8 (keine 68010, 68020 und WarpOS-Versionen
  91. ;          herstellen). Sinnvoll immer dann, wenn in Einzelfällen ein Teil
  92. ;          im Make unmöglich oder nicht sinnvoll ist. Z.B. ein Utility für
  93. ;          PPC-Prozessoren würde die 68k-Aufrufe sinnlos machen.
  94.  
  95. :BEGIN DOSLIB
  96. PFAD=Proj:DOSLIB
  97. NOMAKE=2,3,8
  98. $5=$6 -I$I
  99. $$=Lib:DOSLIB_$0$8
  100. L=PmmLibr F Lib:DosLib_$0 $o
  101. 7%L=List Proj:DOSLIB/obj/ppc/#?.o lformat="ppc-amigaos-ar q Lib:DOSLIB_$0$8 %s%s" >Ram:LibList
  102. 5%X5=Execute Pmm:Batch/ManProto.s Proj:DOSLIB Include:DOSLIB_protos.h
  103. Y0=Execute Pmm:Batch/MakeStubAll.s
  104. 7%Y1=Execute Ram:LibList
  105. :END
  106. ;
  107. ; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
  108. ;
  109. ; Als Demo habe ich das zum vbcc-Compiler gehörende Programm vc gewählt
  110. ; PFAD=    Wo liegen die Sourcen?
  111. ; $9=      Variable, wird in Pmm.Cfg eingefügt, vc muß mit -DAMIGA übersetzt werden
  112. ; $$=      Executable (hier gleich 8 unterschiedliche, aufgeteilt in eigene Verzeich-
  113. ;          nissse in denen auch die .o-Files gelagert werden). Mag etwas übertrieben
  114. ;          aussehen, aber bei 100 .c-Files kämen 800 .o-Files raus. Wer's nicht, oder
  115. ;          anders möchte kann sich das ja umstellen.
  116. ; $L       Link-Lib, Erweiterung zum Standard, hier auskommentiert, vc braucht meine
  117. ;          persönlichen Files nicht. Das muß auch jede Nutzer selber einrichten.
  118. ; $o       Obj-Liste für den Linker (Temp-File)
  119. ; X0       Aufruf Programmes VOR dem Make z.b. Versionsdumper
  120. ; Y0       Copy der 68040-Version ins vbcc-bin-Verzeichnis (zur Sicherheit aber
  121. ;          unter anderem Namen). Und, als Demo, 4 der maximal 8 Versionen werden
  122. ;          kopiert.
  123. ;
  124. :BEGIN vc
  125. PFAD=vbcc://frontend
  126. $9=-DAMIGA
  127. $$=obj/$0/vc
  128. ;
  129. ;     Die folgenden Zeilen definieren .Lib's für den Linker.
  130. ;     Sie sind jetzt auskommentiert, da das eigene Lib's sind und vc
  131. ;     braucht sie definitiv nicht.
  132. ;
  133. ;$L=-Bsymbolic Lib:DOSLIB_$0$8 Lib:All$9
  134. ;7%$L=-Bdynamic Lib:DOSLIB_$0$8 Lib:All$9
  135. 5%X0=Echo "Ich simuliere einen Versionsdumper, der aber nur bei 68040 anläuft."
  136. Y0=Copy obj/$0/vc vbcc://bin/vc_$0
  137. :END
  138.  
  139. ; :BEGIN xxx ist der Anfang einer Programmdefinition. Diese muß mit :END beendet
  140. ; werden. Der Name hinter BEGIN hat keine Bedeutung für's Compilat, er verbindet
  141. ; jedoch diese Definition mit den Dateien List_xxx und Work_xxx und ist auch der
  142. ; Parameter für Pmm 'Pmm -p xxx'. Der Programmname den der Compiler erzeugt ist
  143. ; in $$ festgelegt, ggf. auch mehrmals (siehe oben). BEGIN/END dürfen immer nur
  144. ; im Wechsel genau EINMAL benutzt werden. Alle anderen Zeilen können mit #%, also
  145. ; 0%, 1% ... 9% CPU-typisch gesetzt werden. An Y0 ist zu erkennen, wie eine
  146. ; Funktion nur bei einzelnen CPU's benutzt wird. $L zeigt eine Variante wo es
  147. ; einen Standard-Wert gibt, der in Einzelfällen verändert ist. $$ wiederum ist
  148. ; für alle CPU's einzeln festgelegt. PFAD ist die letzte Möglichkeit, nur eine
  149. ; Definition für alle ($9 und $o dito).
  150.